草庐IT

Java - 特殊 URL 字符

全部标签

ruby-on-rails - 如何防止管道字符在 Rails 3/Ruby 1.9.2 中导致错误的 URI 错误?

在我的应用中实现OAuth2时,我需要处理如下URI:http://localhost:3000/sessions/create/?code=lorem|ipsum不确定这是Rails3还是Ruby1.9.2的问题(可能是URI.parse),但无论如何,WEBrick都会启动ErrorbadURI。有人知道解决方法吗?谢谢。 最佳答案 我最近遇到了同样的需求(和问题)。OnRails3和Ruby1.9.2。这对我们的暂存/生产环境(nginx)来说不是问题,但我很想知道WEBrick的问题所在。原来问题出在URI::Parser.

Ruby:从字符串生成新的正则表达式

有什么方法可以将String转换为Regexp(在Ruby中)?比方说:'example'--->/example/我的目的是动态生成正则表达式。 最佳答案 regexp=Regexp.new(string)或regexp=/#{string}/如果string可能有特殊字符,那么:regexp=Regexp.new(Regexp.escape(string))或regexp=/#{Regexp.escape(string)}/ 关于Ruby:从字符串生成新的正则表达式,我们在Stack

ruby - 通过 Rack::Auth::Basic 有选择地允许某些 url

我已经建立了一个我希望得到最低限度安全保护的博客(即,我只是想将我不认识的随机人员拒之门外,我并没有尝试实现类似NSA的安全措施)。我正在使用toto使用Rack::Auth::Basic来“保护”站点。我想通过index.xml以便博客读者能够在不处理密码的情况下阅读提要(是的,我知道这是我的“安全性”中的一个大漏洞).如何让Rack::Auth::Basic通过这个url?这就是我向网站添加基本身份验证的方式:useRack::Auth::Basic,"blog"do|username,password|[username,password]==['generic','stupid

ruby - 在 ruby​​/ActiveRecord 中生成类似 Instagram 或 Youtube 的不可猜测的字符串 ID

在创建给定ActiveRecord模型对象的实例后,我需要生成一个简短的(6-8个字符)唯一字符串用作URL中的标识符,采用Instagram照片URL的样式(如http://instagram.com/p/P541i4ErdL/,它我只是争先恐后地成为404)或Youtube的视频网址(如http://www.youtube.com/watch?v=oHg5SJYRHA0)。执行此操作的最佳方法是什么?最简单的是createarandomstring重复直到它是唯一的?有没有一种方法可以对整数ID进行散列/洗牌,使用户无法通过更改一个字符来破解URL(就像我对上面的404'sInst

ruby - ruby 是否具有与 synchronize 关键字等效的 Java?

ruby是否有Java中的synchronize关键字?我使用的是1.9.1,但我不太明白执行此操作的优雅方式。 最佳答案 它没有synchronize关键字,但您可以通过Monitor类获得非常相似的东西。以下是ProgrammingRuby1.8一书中的示例:require'monitor'classCounter 关于ruby-ruby是否具有与synchronize关键字等效的Java?,我们在StackOverflow上找到一个类似的问题: http

ruby - 如何在 Heroku 上使用 Ruby Rack 为静态站点设置 URL

我的网站是here.它曾经是一个Django驱动的博客。但是我不再更新它所以我只是想把它变成一个静态的HTML站点。我得到了它并使用RubyRack将它移到了Heroku。但是每个URL都解析为主页。这是因为我的config.ru文件:useRack::Static,:urls=>["/media/images","/media/js","/media/css"],:root=>"public"runlambda{|env|[200,{'Content-Type'=>'text/html','Cache-Control'=>'public,max-age=86400'},File.op

ruby - Ruby 2.0 中的二进制字符串文字

当升级到Ruby2.0时,一个测试用例开始失败:expected="\xD1\x9B\x86"assert_equalexpected,actual带有以下消息:expectedbutwas.actual变量包含从外部库调用中获得的二进制字符串。问题是源文件的默认编码(以及字符串文字)changedinRuby2.0从US-ASCII到UTF-8。 最佳答案 解决方案是更改字符串文字的定义以强制执行其编码。有几个可能的选择可以做到这一点:使用Array#pack(所有版本的Ruby):expected=["d19b86"].pack

ruby - ruby 如何完成这项任务(Ruby 中不区分大小写的字符串搜索和替换)?

我在用Ruby替换字符串时遇到一些问题。我的原文:人之所为不如兽之所为。我想替换为:==What==humandoesisnotlike==what==animaldoes.我在使用gsub时遇到区分大小写的问题。(例如,什么,什么)我想保留原始文本。有什么解决办法吗? 最佳答案 如果我理解正确,这就是你想要做的:puts"Whatthehumandoesisnotlikewhatanimaldoes.".gsub(/(what)/i,'==\1==')输出==人类所做的==不同于==动物所做的。

ruby-on-rails - 使用 Ruby/Rails 进行 base 64 URL 解码?

我正在使用FacebookAPI和RubyonRails,我正在尝试解析返回的JSON。我遇到的问题是Facebookbase64URL对其数据进行编码。Ruby没有内置的base64URL解码。关于base64编码和base64URL编码的区别,seewikipedia.我如何使用Ruby/Rails对此进行解码?编辑:因为有些人阅读有困难——base64URL与base64不同 最佳答案 Dmitry的回答是正确的。它说明了在字符串解码之前必须出现的“=”符号填充。我一直收到格式错误的JSON,最后发现这是由于填充造成的。Rea

ruby 正则表达式 : capture the path of url

我想从任何URL中提取其路径。例如:网址:https://stackoverflow.com/questions/ask路径:questions/ask应该不难:url[/(?:\w{2,}\/).+/]但我认为我使用了错误的模式来“忽略这个”('?:'-不起作用)。什么是正确的方法? 最佳答案 我建议您不要使用正则表达式来执行此操作,而是使用内置的URI库:require'uri'uri=URI::parse('http://stackoverflow.com/questions/ask')putsuri.path#results